草庐IT

SQL 表设置建议

全部标签

ruby-on-rails - Rails 3.x 中 CAS 服务器的设置问题

我已经在ec2服务器上安装了rubyCASServer,使用Rails3.2和Ruby1.9.3并配置了configure.yml文件,我的server:webrickport:9292ssl_cert:/mnt/rubyonrails/testingcas.pem注意:我在生成自签名SSL期间提到了域名fortestingonly.managemyasc.devserverdatabase:adapter:mysql2database:casserverusername:rootpassword:XXXXXhost:localhostreconnect:trueauthenticat

sql - 在 Rails 中使用连接执行 update_all

在这种情况下,Rails对原始SQL的抽象让我抓狂。在MySQL中我可以这样做:UPDATEFROMtasksAStLEFTJOINprojectsaspONt.project_id=p.idSETt.invoice_id=7WHEREp.organization_id==42ANDt.invoice_idISNULL我如何在Rails3.0.1中使用预先加载来做到这一点?我已经尝试了以下所有方法:Tasks.joins(:project).where('projects.organization_id'=>42,:invoice_id=>nil).update_all(:invoic

ruby - 如何在 Ruby 中为 splat 参数设置默认值

为splat参数设置默认值会产生错误:1.9.3-p374:001>defab,*c=nil1.9.3-p374:002?>endSyntaxError:(irb):1:syntaxerror,unexpected'=',expecting';'or'\n'defab,*c=nil^from/Users/me/.rvm/rubies/ruby-1.9.3-p374/bin/irb:16:in`'我尝试过的一些变体也不起作用:1.9.3-p374:003>defab,*c=[]1.9.3-p374:005>defab,(*c)=nil1.9.3-p374:007>defab,(*c=[]

sql - 如何查看 SQL ActiveRecord 生成的内容?

我想检查一些由ActiveRecord生成的查询,但我不需要实际运行它们。有没有办法在返回结果之前获取查询? 最佳答案 这两篇文章都应该可以帮助您做您想做的事。http://weblog.jamisbuck.org/2007/1/8/watching-activerecord-do-it-s-thinghttp://weblog.jamisbuck.org/2007/1/31/more-on-watching-activerecord 关于sql-如何查看SQLActiveRecord生

sql - 用于 250K+ 字符串的通配符搜索的 Fast(er) 方法

我在MySQL数据库中有一个英语词典,其中只有超过250K个条目,我正在使用一个简单的ruby​​前端在字符串的开头使用通配符来搜索它。到目前为止,我一直这样做:SELECT*FROMwordsWHEREwordLIKE'_e__o'甚至SELECT*FROMwordsWHEREwordLIKE'____s'我总是知道单词的确切长度,但除了一个字符之外的所有字符都可能是未知的。这比糖蜜慢,比没有前导通配符的类似查询慢大约15倍,因为无法使用该列的索引。我尝试了几种方法来缩小搜索范围。例如,我添加了26个额外的列,其中包含每个单词的单个字母计数,并首先使用这些列来缩小搜索范围。我也试过按

ruby-on-rails - 设置没有种子数据的数据库

我需要用表格等设置我的数据库,但在某些情况下我不想加载我的种子数据。我也不想每次想忽略我的种子数据时都删除或移动我的db/seeds.rb文件。有没有办法执行rakedb:setup的任务并忽略种子数据? 最佳答案 是的。只需使用以下两个命令:rakedb:createrakedb:schema:loadrakedb:setup所做的只是创建数据库(db:create),从db/schema.rb加载数据(db:schema:load),然后插入种子数据(db:seed)。您可以单独执行这些步骤。

ruby - <RubyGems> 如何更改 gem 环境设置?

我安装了rbenv并设置了ruby​​和gems。现在,如果我运行gemenv,那么我会得到以下信息:RubyGemsEnvironment:-RUBYGEMSVERSION:2.2.2-RUBYVERSION:2.1.0(2013-12-25patchlevel0)[x86_64-darwin13.0]-INSTALLATIONDIRECTORY:/Users/myusername/Tools/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0-RUBYEXECUTABLE:/Users/myusername/Tools/.rbenv/versions

ruby-on-rails - Development.log 日志文件不记录 Rails SQL 查询

我在这里关注MichaelHartl的Rails教程:http://ruby.railstutorial.org/chapters/modeling-and-viewing-users-one#top我使用此命令在单独的窗口中跟踪SQL查询:tail-flog/development.log然而,当我在沙盒Rails控制台中时,日志不会用SQL语句更新,而是显示在Rails控制台中。我该如何纠正这种行为?我应该补充一点,我的数据库迁移和对数据模型(新表等)的更改都反射(reflect)在日志中。仅省略由Rails控制台内的方法传播的SQL语句(而是显示在Rails控制台中)。这是我的G

ruby-on-rails - 用于测试服务对象的 Rspec 建议

我正在为涉及多个模型的服务对象编写Rspec测试,但我觉得我的测试过于依赖方法的内部结构,因此意义不大。这是一个例子:classMealServicerdefself.serve_meal(meal,customer)meal.update_attributes(status:"served",customer_id:customer.id)order=customer.orderOrderServicer.add_meal_to_order(meal,order)CRM.update_customer_record(customer)//externalAPIcallendend我想

ruby - 用 puppet 设置环境变量

我正在尝试找出使用puppet设置一些环境变量的最佳方法。我可以使用exec并执行exportVAR=blah。但是,这只会持续本届session。我还考虑过将它添加到文件的末尾,例如bashrc。但是,我认为没有可靠的方法来检查它是否已准备就绪;所以它最终会随着puppet的每次运行而添加。 最佳答案 我会看一下thisrelatedquestion.*.sh/etc/profile.d中的脚本在用户登录时被读取(正如帖子所说,同时/etc/profile来源)export中放置在/etc/profile.d中的任何脚本中的变量因